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AMENDMENTS TO THE CLAIMS 

This listing of claims will replace all prior versions and listings of claims in the application. 
Listing of Claims: 

Claim 1 (Canceled). 
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Claim 2 (Currently Attended): A system for encoding one or more repetitive data blocks in data 

communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting the data. 
communicated from a server to a client device, the encoder module extracting data 
blocks from different communication sessions from the intercepted data, each 
extracted block having a destination address of [[a]] tbeclient device te^\4weh-the- 
ftadrafr foH . dntn h1ock 4fr4esfaied » the encoder module determining w hether the client 
device and that is supported for decoding by at least one corresponding decoder 
module based on the destination address of the client device, and the encoder module 
passing through the data when the not having a - wpp efted destination address of the 
client device is not supported for decoding bv a decoder module ; and 
a memory, accessible to the encoder module* for storing the contents of one or more data 
blocks previously transmitted by the encoder module wherein the encoder module 
determines whether there is a match between the contents Of each of the extracted 
data blocks and the contents of at least one previously transmitted data block, 
wherein the memory comprises a least recently used data structure for storing one or more 
previously transmitted unique data blbcks, said least recently used data structure 
having a maximum capacity and each of the previously transmitted unique data blocks 
having a unique identifier and a position in an order of most recently used to least 
recently used of the one or more stored blocks, 
wherein responsive to said match, the encoder module encodes the respective extracted 
data block, transmits the respective extracted data block in encoded form to the at 
least one corresponding decoder module and associates the previously transmitted 
data block having the matching contents with the position in the least recently used 
data structure indicating the most recently used previously transmitted data block, and 
wherein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module. 

Claim 3 (Previously Presented): The system of claim 2 wherein the encoded form of the 
respective extracted data block is transparent to one or more nodes in the network. 
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Claim 4 (Previously Presented): The system of claim 2 wherein the encoder module is coupled 
vi a a switch in a physical connection between two nodes of the network, responsive to a first 
configuration of the switch, the encoder module processing data that traverse the physical 
connection between these two nodes, and responsive to a second configuration of the switch, the 
data bypassing the encoder module. 

Claim 5 (Previously Presented): The system of claim 2 wherein the encoder module operates in a 
node in the network and decides a route for the respective extracted data block to the at least one 
corresponding decoder module supporting its destination address. 

Claim 6 (Previously Presented): The system of claim 2 wherein the encoder module, responsive 
to a match in contents, transmits an indicator, identifying that the contents of a respective data 
block have been previously transmitted* 

Claim 7 (Previously Presented): The system of claim 6 wherein the indicator is a special symbol. 

Claim 8 (Previously Presented): The system of claim 6 wherein the indicator is an extra header. 

Claim 9 (Previously Presented): The system of claim 2 wherein at least one respective data block 
is a packet pay load. 

Claim 10 (Previously Presented): The system of claim 2 wherein at least one respective data 
block is a portion of a packet payload. 

Claim 1 1 (Previously Presented): The system of claim 2 wherein the encoder module encodes at 
least one extracted data block using a synchronization mechanism for verifying the identification 
of the one or more previously transmitted data blocks with the at least one corresponding decoder 
module supporting the destination, address of the extracted data block- 
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Claim 12 (Previously Presented): The system of claim 1 1 wherein the synchronization 
mechanism is an explicit synchronization mechanism. 

Claim 13 (Previously Presented): The system of claim 1 1 wherein the synchronization 
mechanism is an implicit synchronization mechanism. 

Claim 14 (Previously Presented): The system of claim 1 1 wherein the implicit synchronization 
mechanism is a reliable network transport protocol 

Claim 1 5 (Previously Presented): The system of claim 2 further comprising the encoder module, 
responsive to no match between the contents of the respective extracted data block and the 
contents of at least one of the previously transmitted blocks, determining whether to delete at 
least one of the previously transmitted data blocks in the memory, and storing the respective 
extracted data block in intercepted form in the memory. 

Claim 16 (Cancelled). 
Claim 17 (Cancelled). 
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Claim 1 8 (Currently Amended); A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting the data. 
communicated from at least one server to at least one client device, the encoder 



and the encoder module pa 
destination address of the c 
module; and 



module extracting data blocks from different communication, sessions from the 
intercepted data, each extracted block having a destination address of [[a]] tbe_client 
device to which the extracte d data block is destined, the encoder module determining. 
whether the client device ar d-that is supported for decoding by at least one 



corresponding decoder module based on the destination ad dress of the client device, 



sing through data when the not having a su pport e d 
lent device is not supported for decoding bv a decoder 



a memory, accessible to the endoder module, having a least recently used data structure 



for storing the contents of C 



:ne or more unique data blocks previously transmitted by 
the encoder module, said least recently used data structure having a maximum 
capacity and each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks, 
wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 
wherein responsive to said match, the encoder module encodes. the respective extracted 
data block and transmits the respective extracted data block in encoded form to the at least one 
corresponding decoder module, and 

wherein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module, stores the 
extracted data block in the least recently u$ed data structure, and associates the position of most 
recentlv used with the extracted data block. 



-6- 

PAGE 8/44 < RCVD AT 4/2512007 4:47:39 PM [Eastern Daylight Time] * SVR:USPT0-EFXRF-1/5 * DNlS:2738300 < CSID:651735I102 * DURATION (mm-ss):1244 



04/25/2007 15:43 6517351102 



SHUMAKER & SIEFFERT 



PAGE 03/ 44 



Application Number 09/915,939 

Amendment dated April 25, 2007 

Responsive to Office Action mailed January 25, 2007 

Claim 19 (Previously Presented): The system of claim 18 

wherein, responsive to the least recently used data structure being at the maximum 

capacity, the encoder module deletes the previously transmitted data block having the 
order position of the least recently used data block. 
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Claim 20 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting the data, the 

encoder module extracting data blocks from different communication sessions from 

the intercepted data; 

a memory, accessible to the encoder module, having a least recently used data structure 
for storing the contents of one or more unique data blocks previously transmitted by 
the encoder module, said least recently used data structure having a maximum, 
capacity and each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks, 
wherein, responsive to the least recently used data structure being at the maximum 

capacity, the encoder module deletes the previously transmitted data block having the 
order position of the least recently used data block, 
wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 
wherein responsive to said match 5 the encoder module encodes the respective extracted 
data block and transmits the respective extracted data block in encoded form to at 
least one corresponding decoder module, and 
wherein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module, 
stores the extracted data block in the least recently used data structure, and associates 
the position of most recently used with the extracted data block; and 
a synchronization mechanism including a same size for the least recently used data 
structure as the size of a second least recently used data structure accessible by the 
corresponding decoder module receiving the respective extracted data block, and a 
reliable network transport protocol being used for the transmission of the respective 
extracted data block. 
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Claim 21 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting the data, the 

encoder module extracting data blocks from different communication sessions from 

the intercepted data; 

a memory, accessible to the encoder module, having a least recently used data structure 
for storing the contents of one or more unique data blocks previously transmitted by 
the encoder module, said least recently used data structure having a maximum 
capacity and each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks, 

wherein, responsive to the least recently used data structure being at the maximum 

capacity, the encoder module deletes the previously transmitted data block having the 
order position of the least recently used data block, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block, 

wherein responsive to said match, the encoder module encodes the respective extracted 
data block and transmits the respective extracted data block in. encoded form to at 
least one corresponding decoder module, and 

wherein responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module, 
stores the extracted data block in the least recently used data structure, and associates 
the position of most recently used with the extracted data block; and 

a synchronization mechanism including an indicator for each transmitted extracted data 
block indicating whether the data block has been associated with the least recently 
used data structure and an installed flag associated with each of the previously 
transmitted data blocks in the least recently used data structure, the installed flag 
indicating whether the associated data block has been stored in a second least recently 
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used data structure accessible by the corresponding decoder module that has received 

the respective extracted data block- 
Claim 22 (Previously Presented): The system of claim 21 wherein the installed flag is updated 
after a fixed amount of time after transmission of the data block. 

Claim 23 (Previously Presented): The system of claim 21 wherein the installed flag is updated 
responsive to a notification from the corresponding decoder module that the associated data 
block has been stored in. the second least recently used data structure. 

Claim 24 (Previously Presented): The system of claim 2 wherein the memory stores a data 
structure for associating a signature with one or more of the previously transmitted data blocks, 
and wherein the encoder module computes a signature for the respective extracted data block, 
compares the computed signature with at least one signature associated with the one or more 
previously transmitted data blocks, and responsive to a match in signature, selecting the one or 
more previously transmitted data blocks having the match in signature for content comparison 
with the respective extracted data block. 

Claim 25 (Previously Presented): The system of claim 24 wherein the data structure for 
associating a signature with one or more of the previously transmitted data blocks is a hash table 
having one or more bins. 
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Claim 26 (Previously Presented): A system for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

an encoder module intercepting the data and extracting data blocks from different 
communication sessions from the intercepted data, each extracted block having a 
destination address of a client device to which the extracted data block is destined and 
that is supported for decoding by at least one corresponding decoder module, and the 
encoder module passing through data not having a supported destination address; 

a memory, accessible to the encoder module, for storing the contents of one or more data 
blocks previously transmitted by the encoder module; and 

a hash table having one or more bins for associating a signature with one or more of the 
previously transmitted data blocks, 

wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blocks and the contents of at least one previously 
transmitted data block by computing a signature for the respective extracted data 
block and comparing the computed signature with at least one signature associated 
with the one or more previously transmitted data blocks, the computed signature value 
being less than the number of hash table bins, 

wherein, responsive to a match in signature/the encoder selects the one or more 
previously transmitted data blocks having the match in signature for content 
comparison with the respective extracted data block, encodes the respective extracted 
data block and transmits the .respective extracted data block in encoded form to the at 
least one corresponding decoder module, and 

wherein, responsive to no match, the encoder module transmits the respective extracted 
data block in intercepted form to the at least one corresponding decoder module. 
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Claim 27 (Previously Presented): A system for encoding one or more repetitive data blocks in 

data communicated over a network comprising: 

an encoder module intercepting the data and extracting data blocks from different 

communication sessions frorri the intercepted data, each extracted block having a 

destination address of a client device to which, the extracted data block is destined and 

i 

that is supported for decoding by at least one corresponding decoder module, and the 
encoder module passing through data not having a supported destination address; 
a memory, accessible to the encoder module, for storing the contents of one or more data 

blocks previously transmitter: . by the encoder module; and 
a hash table having one or more bins for associating a signature with one or more of the 

previously transmitted data b ocks, 
wherein the encoder module determines whether there is a match between the contents of 
each of the extracted data blccks and the contents of at least one previously 
transmitted data block by computing a signature for the respective extracted data 
block and comparing the computed signature with at least one signature associated 
with the one or more previously transmitted data blocks, the computed signature value 
being computed as a modulo of the number of bins, 
wherein, responsive to a match b signature, the encoder selects the one or more 
previously transmitted data t locks having the match in signature for content 
comparison with the respective extracted data block, encodes the respective extracted 

: respective extracted data block in encoded form to the at 
:der module, and 

( the encoder module transmits the respective extracted 



data block and transmits the 
least one corresponding decc 
wherein, responsive to no match 



Claim 28 (Previously Presented): The 
module for encapsulating the extracted 



Claim 29 (Previously Presented): The 
data blocks is included in a packet, and 



data block in intercepted forn to the at least one corresponding decoder module. 



s ystem of claim 2 further comprising an encapsulation 
data blocks for transport over the network. 



<;y$tem of claim 28 wherein at least one of the extracted 
the packet is encapsulated as one packet. 
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Claim 30 (Previously Presented): The system of claim 28 wherein at least one of the extracted 
data blocks is included in a packet and the packet is encapsulated with at least one other packet in 
an outgoing packet for transmission. 

Claim 3 1 (Previously Presented); The system of claim 28 wherein the encapsulation of at least 
one of the extracted data blocks is transparent to one or more nodes in the network. 

Claim 32 (Previously Presented): The system of claim 28 wherein the encapsulation module 
comprises a timer mechanism for ensuring that the at least one extracted data block is held in a 
buffer coupled to the encapsulation module for no more than a pre-determined maximum time 
before being transmitted. 

Claim 33 (Previously Presented): The system of claim 30 wherein the encapsulation module 
comprises a timer mechanism for ensuring that the at least one extracted data block is held in a 
buffer coupled to the encapsulation module for no more than a pre-determined maximum time 
before being transmitted. 

Claim 34 (Previously Presented): The system of claim 28 wherein the encoder module encodes 
at least one data block at a first layer of a model describing the flow of data across a network and 
the encapsulation module encapsulates the at least one extracted data block at a second layer of 
the model. 

Claim 35 (Previously Presented): The system of claim 34 wherein the first and second layers arc 
at the same layer of the model. 

Claim 36 (Previously Presented): The system of claim 35 wherein one of the layers is a 
connection-oriented layer and the other layer is a connectionless layer. 
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Claim 37 (Currently Amended): A system for encoding one or more repetitive data blocks in 

data communicated over a network comprising: 

an encoder module intercepting the datk communicated from a server to a client device 
and extracting data blocks from different communication sessions from the 
intercepted data, each extracted block having a destination address of [[a]] the_clicnt 
device to whi"h ^ ^rtmnt n H H ntn hlnok jg d es&ra k the encoder module determining 
whether the client device an d that is supported for decoding by at least one 
corresponding decoder module based on the destination address of the client device, 
and the encoder module passing through the data when the flfr^ving-a^upperted 
destination address of the client device is not supported for decoding by a decoder 
module; and 

a memory, accessible to the encoder module, for storing the contents of one or more data 

blocks previously transmitted by the encoder module, 
wherein the encoder module determines whether there is a match between the contents of 

each of the extracted data blocks and the contents of at least one previously 

transmitted data block, 
wherein, responsive to said match, the encoder module encodes the respective extracted 

data block and transmits the respective extracted data block in encoded form to the at 

Least one corresponding decoder module, 
wherein responsive to .no match, the encoder module transmits the respective extracted 

data block in intercepted form to the at least one corresponding decoder module, and 
wherein the encoder module receives routing information in accordance with a routing, 

protocol over the network from each of one or more corresponding decoder modules 

with which it communicates and determines the one or more addresses supported by 

each respective decoder module from the routing information, wherein the routing 

information includes network topology info rmation for the network. 

Claim 38 (Currently Amended): The system of claim 37 wherein the encoder module determines 
the network topology information based upon the routing information from the one or more 
decoder modules. 

-14- . • 
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Claim 39 (Previously Presented): The system of claim 38 wherein, responsive to multiple 
decoder modules in the network supporting the same address, the encoder module determines a 
destination decoder module for one or more extracted data blocks based upon network topology 
information and routing criteria. 

Claim 40 (Previously Presented); The system of claim 38 wherein the routing criteria includes 
routing cost. 

Claim 41 (Previously Presented): The system of claim 38 wherein the routing criteria includes 
routing distance. 

Claim 42 (Currently Amended): A system for decoding one or more repetitive data blocks in 

data communicated over a network comprising: 

a decoder module being coupled in. the network, the decoder module transmitting; routing 
information over the network to a corresponding encoder modul e in accordance with 
a routing protocol the routing information including network topology information 
for the network and identifying one or more addresses of client d evices that the 
decoder module supports, the decoder module receiving data blocks for different 
communication sessions from a the corresponding encoder module, each of the data 
blocks having a destination address of a client device to which the extracted data 
block is destined; and 

a memory accessible to the decoder module for storing the contents of one or more data 
blocks previously received from the corresponding encoder module wherein the 
decoder module determines whether the contents of each of the received data blocks 
is in encoded form, 

wherein the memory stores the previously received data blocks in a least recently used 
data structure for storing one or more previously received unique data blocks, the least 
recently used data structure having a maximum capacity and each of the previously 
received unique data blocks having a unique identifier and a position in an order of 
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most recently used to least recently u sed of the one or more previously received 

blocks, 

wherein responsive to the respective data block being in encoded form, the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block and associates the previously received data block 
having the matching contents with the position in the least recently used data structure 
indicating the most recently used previously received data, and 

wherein responsive to the data block being unencoded, the decoder module stores the 
contents of the respective received data block as a previously received data block. 

Claim 43 (Previously Presented); The system of claim 42 wherein the decoder module is 
coupled via a switch in a physical connection between two nodes of the network, responsive to a 
first configuration of the switch, the encoder module processing data that traverse the physical 
connection between these two nodes, and responsive to a second configuration of the switch, the 
data bypassing the decoder module. 

Claim 44 (Previously Presented): The system, of claim 42 wherein the decoder module operates 
in a node in the network and decides a route for a decoded data block to its destination address. 

Claim 45 (Previously Presented): The system of claim 42 wherein the decoder module receives 
an indicator for identifying that the contents of at least one encoded data block have been 
previously transmitted to the decoder module. 

Claim 46 (Previously Presented); The system of claim 45 wherein the indicator is a special 
symbol. 

Claim 47 (Previously Presented): The system of claim 45 wherein the indicator is an extra 
header. 
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Claim 48 (Previously Presented): The system of claim 42 wherein at least one encoded data 
block is a packet payload. 

Claim 49 (Previously Presented): The system of claim 42 wherein at least one encoded data 
block is a portion of a packet payload. 

Claim 50 (Previously Presented): The system of claim 42 wherein the decoder module decodes 
at least one encoded data block using a synchronization mechanism for verifying the 
identification of the one or more previously received data blocks from a corresponding encoder 
module. 

Claim 51 (Previously Presented): The system of claim 50 wherein the synchronization 
mechanism is an explicit synchronization mechanism. 

Claim 52 (Previously Presented): The system of claim 50 wherein the synchronization 
mechanism i$ an implicit synchronization mechanism. 

Claim 53 (Previously Presented): The system of claim 52 wherein the implicit synchronization 
mechanism is a reliable network transport protocol. 

Claim 54 (Previously Presented): The system of claim 50 wherein the synchronization 
mechanism is a reliable network transport protocol. 

Claim 55 (Previously Presented): The system o f claim 42 wherein responsive to the data block 
being unencoded, the decoder module stores the contents of the respective received data block a$ 
a previously received data block further comprises determining whether to delete at least one of 
the previously received data blocks. 



Claim 56 (Cancelled). 
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Claim 57 (Cancelled). 

Claim 58 (Previously Presented); The system of claim 42 wherein the decoder module, 
responsive to no match in contents between the respective received data block and any one of the 
previously received data blocks, stores the respective received data block in the least recently 
used data structure, and associates the position of most recently used with the respective received 
data block. 
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Claim 59 (Previously Presented): The system of claim 58 further comprising: responsive to the 
least recently used data structure being at the maximum capacity, storing the respective received 
data block in the least recently used data structure comprises replacing the previously received 
data block having the order position of least recently used data block with the respective received 
data block. 

Claim 60 (Previously Presented): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module receiving data blocks from an encoder module; 

a memory having a least recently used data structure for storing one or more previously 
received unique data blocks, each of the previously received unique data blocks 
having a unique identifier and a position from a most recently used to least recently 
used of the one or more previously received blocks; 

a synchronization mechanism including a same size for the least recently used data 
structure as the size of a second least recently used data structure accessible by the 
corresponding encoder module that transmitted the respective received data block, a 
reliable network transport protocol being used for the transmission of the respective 
received data block, 

wherein the decoder module determines whether the contents of each of the received data 

blocks is in encoded form, 
wherein responsive to the respective data block being in encoded form, the decoder 

module selects the contents of a matching previously received block as the contents 

for the respective encoded block, and 
wherein .responsive to the data block being unencoded, the decoder module stores the 

contents of the respective received data block as a previously received data block. 
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Claim 61 (Previously Presented): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module receiving data blocks from an encoder module; 
a memory having a least recently used data structure for storing one or more previously 
received unique data blocks, each of the previously received unique data blocks 
having a unique identifier and a position from a most recently used to least recently 
used of the one or more previously received blocks; 
a synchronization mechanism including a same size for the least recently used data 
structure as the size of a second least recently used data structure accessible by the 
corresponding encoder module, an indicator for each received data block indicating 
whether the received data block has been previously associated with the second least 
recently used data structure, and an installation acknowledgement transmitting by the 
decoder module to the corresponding encoder module responsive to an installation of 
each received block in the lea$t recently used data structure, 
wherein the decoder module determines whether the contents of each of the received data 

blocks is in encoded form 3 
wherein responsive to the respective data block being in encoded form, the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block, and 
wherein responsive to the data block being unencoded, the decoder module stores the 
contents of the respective received data block as a previously received data block. 
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Claim 62 (Previously Presented): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module receiving data blocks from an encoder module; 

a memory having a least recently used data structure for storing one or more previously 

received unique data blocks, each of the previously received unique data blocks 

having a unique identifier and a position from a most recently used to least recently 

used of the one or more previously received blocks; 
a synchronization mechanism wherein the decoder module receives a version number of 

the previously received data block having the matching contents, the version number 

indicating how many times the identifier for this data block has been re-used, 
wherein the decoder module determines whether the contents of each of the received data 

blocks is in encoded form, 
wherein, responsive to the respective data block being in encoded form, the decoder 

module selects the contents of a matching previously received block as the contents 

for the respective encoded block, and 
wherein responsive to the data block being unencoded, the decoder module stores the 

contents of the respective received data block as a previously received data block. 

Claim 63 (Previously Presented): The system of claim 42 wherein the system further comprises a 
decapsulation module for decapsulating a block of data received over the network from a source 
address supported by a corresponding encoder module, 

Claim 64 (Previously Presented): The system of claim. 63 wherein the received data block is 
included in a packet, and the packet has been decapsulated as one packet- 
Claim 65 (Previously Presented): The system of claim 63 wherein the received data block is 
included in a packet and the packet has been decapsulated with at least one other packet in an 
outgoing packet transmitted from a source address supported by a corresponding encoder 
module. 
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Claim 66 (Previously Presented): The system of claim 63 wherein the decapsulation module 
decapsulates the received block of data at a first layer of a model describing the flow of data 
across a network and the decoder module decodes the received block of data at a second layer of 
the model. 

Claim 67 (Previously Presented): The system of claim 66 wherein the first layer and the second 
layer are the same layer. 

Claim 68 (Previously Presented): The system of claim 66 wherein one of the layers is a 
connection-oriented layer and the other layer is a connectionless layer* 

Claim 69 (Currently Amended): A system for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

a decoder module that transmits to the encoder module over the network routing 

information in accordance with a routing protocol . the routi ng information including 

network topology information for the network for identifying one or more addresses 

of client devices that the decoder module supports, the decoder module receiving data 

blocks from an encoder module; and 
a memory' accessible to the decoder module for storing the contents of one or more of the 

data blocks previously received from the encoder module* 
wherein the decoder module determines whether the contents of each of the received data 

blocks is in encoded form, 
wherein responsive to the respective data block being in encoded form, the decoder 

module selects the contents of a matching previously received block as the contents 

for the respective encoded block, and 
wherein responsive to the data block being unencoded, the decoder module stores the 

contents of the respective received data block as a previously received data block. 

Claim 70 (Previously Presented): The system of claim 69 wherein the decoder module 
participates in one or more routing protocols for obtaining routing information. 
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Claim 71 (Currently Amended): A system for decreasing one or more repetitive data blocks in 

data communicated over a network comprising: 

an encoder module, coupled in the network, the encoder module intercepting the data, the 
encoder module extracting data blocks from different communication sessions from 
the intercepted data, each extracted block having a destination address of a client 
device to which the extracted data block is destined, the encoder module determining 
whether the client device and th at is supported for decoding by at least one 
corresponding decoder module based on the destination address of the client device, 
and the encoder module passing through the data when the get-hav kift a s uppo rted- 
destination address of the client device that is not suppo rted for decoding by at least 
one decoder module ; 

a first memory, accessible to the encoder' module, for storing the contents of one or more 

data blocks previously transmitted by the encoder module, 
wherein the encoder module determines whether there is a match between the contents of 

each of the extracted data blocks and the contents of at least one previously 

transmitted data block, 
wherein responsive to a match, the encoder module encodes the respective extracted data 

block and transmits the respective extracted data block in encoded form to the at least 

one corresponding decoder module, and responsive to no match, the encoder module 

transmits the respective extracted data block in intercepted form to the at least one 

corresponding decoder module; 
the at least one corresponding decoder module being coupled in the network, the decoder 

module receiving data blocks for different communication sessions from the encoder 

module; and 

a second memory accessible to the decoder module for storing the contents of one or 
more data blocks previously received from the encoder module, 

wherein the at least one corresponding decoder module determines whether the contents 
of each of the received data blocks is in encoded form, 
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wherein, responsive to the respective data block being in encoded form, the decoder 
module selects the contents of a matching previously received block as the contents 
for the respective encoded block, and responsive to the data block being unencoded, 
the decoder module stores the contents of the respective received data block as a 
previously received data block, and 

wherein the decoder module transmits routing information in accordance with a routing. 
protocol, the routing information including netw ork topology information for the 
network for identifying one or more addresses it supports over the network to the 
encoder module. 

Claim 72 (Currently Amended): A method for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

recei ving routing information in accordance with a routing protocol over the network 
from one or more decoder modules , the routine information including network 
topology information for the network ; 
determinin g, from the routing information, one or more destination addresses of client 
devices te^whieh-fe o data is d o sti fledWthat is supported by each respective decoder 
module #om4he-reutm g information ; 
intercepting the data communicated from a server to a client device;; 
extracting data blocks from different communication sessions from the intercepted data, 
each extracted block having one o f the a destination addresses for the client device to 
which the intercepted data in destined s^^€H^e4je rHd e ood,i: ^g; 
passing through the_data when the norii avin g a sup port e d destination address of the client 
device to which the intercepted data is destined is not one of the client devices 
supported for decoding bv the one or more decoder modules; 
storing the contents of one or more data blocks previously transmitted; 
determining whether there is a match between the contents of each of the extracted data 
blocks and the contents of at least one previously transmitted data block; 
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responsive to a match, encoding the respective extracted data block, and transmitting the 
respective extracted data block in encoded form to the at least one corresponding 
decoder module; and 

responsive to no match, the encoder module transmitting over the network the respective, 
extracted data block in intercepted form. 

Claim 73 (Previously Presented): The method of claim 72 further comprising responsive to a 
match in contents, transmitting an indicator for identifying that the contents of a respective data 
block have been previously transmitted. 

Claim 74 (Previously Presented): The method of claim 72 further comprising synchronizing the 
identification of the one or more previously transmitted data blocks with at least one 
corresponding decoder module supporting the destination address of the extracted data block. 

Claim 75 (Previously Presented): The method of claim 72 further comprising, responsive to no 
match between the contents of the respective extracted data block and the contents of at least one 
of the pre viously transmitted blocks, determining whether to delete at least one of the previously 
transmitted data blocks in the memory, and storing the respective extracted data block in 
intercepted form in the memory. 

Claim 76 (Previously Presented): The method of claim 72 wherein. Storing the contents of one or 
more data blocks previously transmitted comprises storing one or more previously transmitted 
unique data blocks in a least recently used data structure, said least recently used data structure 
having a maximum, capacity and each of the previously transmitted unique data blocks having a 
unique identifier and a position in an. order of most recently used to least recently used of the one 
or more stored blocks. 
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Claim 77 (Currently Amended): A method for encoding one or more repetitive data blocks in 
data communicated over a network comprising: 

intercepting fee data communicated from at lea st one server to at least one client device; 
extracting data blocks from different communication sessions from the intercepted data, 
each extracted block having a destination address of [[aj] thedient device to which 
the extracted data block is destined and that flptprminin p. based on the destination. 
address of the client device, ■whether the client device is supported for decoding_bvat_ 
least one corresponding decoder module : 
passing through the data when tte^viB&^ppofted thedesti nation address of the client 
device to which the intercepted data is destined is n ot supported for decoding by the at 
least one corresponding decoder module: 
storing one or more previously transmitted unique data blocks in a least recently used data 
structure, each of the previously transmitted unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the 
one or more stored blocks; 
determi ning whether there is a match between the contents of each of the extracted data 

blocks and the contents of at least one previously transmitted data block; 
responsive to a match in contents., encoding the respective extracted data block, 

transmitting the respective extracted data block in encoded form to the at least one 
corresponding decoder module, and associating the previously transmitted data block 
having the matching contents with the position in the least recently used data structure 
indicating the most recently used previously transmitted data block; and 
responsive to no match, transmitting over the network the respective extracted data block 
in intercepted form. 

Claim 78 (Previously Presented): The method of claim 76 further comprising, responsive to no 
match between the contents of an extracted data block and the contents of one of the previously 
transmitted data blocks, storing the extracted data block in the least recently used data structure, 
and associating the position of most recently used with the extracted data block. 
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Claim 79 (Previously Presented): The method of claim 78 further comprising; 

responsive to the least recently used data structure being at the maximum capacity, 
deleting the previously transmitted data block having the order position of least 
recently used data block. 

Claim 80 (Previously Presented): The method of claim 79 further comprising encoding at least 
one data block at a first layer of a model describing the flow of data across a network and the 
encapsulating the at least one extracted data block at a second layer of the model. 

Claim 81 (Previously Presented): The method of claim 80 wherein one of the layers is a 
connection-oriented layer and the other layeris a connectionless layer. 



Claim 82 (Cancelled). 



Claim S3 (Previously Presented): The method of claim 72 further comprising determining 
network topology information based upon the routing information from the one or more decoder 
modules. 

Claim 84 (Previously Presented): The method of claim 83 further comprising responsive to 
multiple decoder modules in the network supporting the same address, determining a destination 
decoder module for one or more extracted data blocks based upon network topology information 
and routing criteria. 
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Claim 85 (Currently Amended): A method for decoding one or more repetitive data blocks in 
data communicated over a network comprising: 

transmitting routing information in accordance w ith a routine protocol for identifying one 
ot more addresses of client devices that a decoder module supports over a network to 
an encoder mnHule, wherein the.routing information includes network topology. 
information for the network : 
receiving data blocks with the decoder module for different communication sessions from 
the encoder module; 

storing the contents of one or more data blocks previously received from the encoder 
module; 

determining whether the contents of each of the received data blocks is in encoded form; 
responsive to the respective data block being in encoded form, selecting the contents of a 

matching previously received block as the contents for the respective encoded block; 

and 

responsive to the data block being unencoded, storing the contents of the respective 
received data block as a previously received data block. 

Claim 86 (Previously Presented): The method of claim 85 further comprising receiving an 
indicator for identifying that the contents of at least one encoded data block have been previously 
transmitted to the decoder module. 

Claim. 87 (Previously Presented): The method of claim 85 further comprising the identification 
of the one or more previously received data blocks from a corresponding encoder module. 

Claim 88 (Previously Presented): The method of claim 85 further comprising responsive to the 
data block being unencoded, storing the contents of the respective received data block as a 
previously received data block further comprises determining whether to delete at least one of the 
previously received data blocks. 
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Claim 89 (Previously Presented): The method of claim 85 wherein storing the previously 
received data blocks further comprises storing one or more previously received unique data 
blocks in a least recently used data structure, the least recently used data structure having a 
maximum capacity and each of the previously received unique data blocks having a unique 
identifier and a position in an order of most recently used to least recently used of the one or 
more previously received blocks. 

Claim 90 (Previously Presented): The method of claim 89 farther comprising responsive to a 
match in contents, associates the previously received data block having the matching contents 
with the position in the least recently used data structure indicating the most recently used 
previously received data block. 

Claim 91 (Previously Presented): The method of claim 89 further comprising responsive to no 
match in contents between the respective received data block and any one of the previously 
received data blocks, storing the respective received data block in the least recently used data 
structure, and associating the position of most recently used with the respective received data 
block. 

Claim 92 (Previously Presented): The method of claim 91 further comprising: responsive to the 
least recently used data structure being at the maximum capacity, deleting the previously received 
data block having the order position of least recently used data block. 

Claim 93 (Previously Presented): The method of claim 85 further comprising decapsulating the 
received block of data at a first layer of a model describing the flow of data across a network and 
decoding the received block of data at a second layer of the model. 

Claim 94 (Previously Presented): The method of claim 93 wherein the first layer and the second 
layer are the same layer. 
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Claim 95 (Previously Presented): The method of claim 94 wherein one of the layers is 
connection-oriented layer and the other layer is a connectionless layer. 

Claim 96 (Canceled), 
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